php - 从 php 对象访问@attribute
全部标签 我正在寻找一种优雅的方式来将存储在哈希中的值分配给预先存在的对象。需要明确的是,如果我有一个对象,比如具有两个属性的obj,比如名称和年龄,我想分配来自哈希的值而不做类似的事情:obj.name=hash[:name]obj.age=hash[:age]感谢您的关注。西蒙妮 最佳答案 最好的办法可能是简单地定义一个像update_attributes这样的方法,它接受一个散列并在类的实例方法中执行它。扩展其他人所写的内容以及您似乎需要的内容我认为您最好的选择是:hash.keys.eachdo|key|m="#{key}="obj.
谁能解释一下d1为什么大于d2?他们是同一个该死的约会对象(或者至少在我看来他们是这样的)。Loadingdevelopmentenvironment(Rails3.0.8)ruby-1.9.2-p180:001>d1=Event.first.updated_at=>Thu,22Sep201102:24:28PDT-07:00ruby-1.9.2-p180:002>d2=Time.zone.parse("2011-09-22T02:24:28-07:00")=>Thu,22Sep201102:24:28PDT-07:00ruby-1.9.2-p180:003>d1.class=>Act
在ruby中你可以去a={}a['a']=82a['b']='foo'putsa['a']#82我希望我可以使用点符号,例如javascript。将a.a#82有没有办法在ruby中构建对象文字并使用点表示法访问它们? 最佳答案 您可以创建一个Struct.A=Struct.new(:a,:b)a=A.new(82,'foo')putsa.a#=>82编辑:你甚至可以做到a={}a['a']=82a['b']='foo'Struct.new(*a.keys).new(*a.values)
我知道序列化对象是(据我所知)有效深度复制对象的唯一方法(只要它不像IO之类的那样是有状态的),但它是一个比其他方式特别有效?例如,由于我使用的是Rails,所以我总是可以使用ActiveSupport::JSON、to_xml-据我所知,编码对象是其中之一最被接受的方法来做到这一点。我希望编码可能是其中最有效的,因为它是Ruby内部的,但我是否遗漏了什么?编辑:请注意,它的实现是我已经涵盖的内容-我不想替换现有的浅拷贝方法(如dup和clone),所以我最终可能会添加Object::deep_copy,其结果是上述方法中的任何一个(或您的任何建议:)开销最少。
哈希:p:{:headline=>"ManagingDirectoratTestcompanyname",:pid=>"0tSsRvCR7r",:first_name=>"John",:last_name=>"Doe",:industry=>"FinancialServices",:summary=>nil,:public_profile_url=>"http://www.linkedin.com/pub/john-doe/7a/78/606",:distance=>0}尝试调用p.pid但出现错误:EXCEPTION:undefinedmethod`pid'for#所有其他元素都可以
我正在将Rails3应用程序迁移到Rails4,并且正在将attr_accessible属性转换为Controller中的强参数。APIDocumentation显示如何“允许”属性:defperson_paramsparams.require(:person).permit(:name,:age)end然而,我的绝大多数属性都是批量分配安全的。我只需要将:account_id和:is_admin等几个属性列入黑名单。是否可以将属性列入黑名单而不是将几乎所有属性列入白名单?例如:defuser_paramsparams.require(:user).exclude(:account_i
我有一个名为test.rb的Ruby文件ff="ff"deftestputsffend我执行它,得到错误:test.rb:3:in`test':main:Object(NameError)的未定义局部变量或方法`ff'这是什么原因?有文档解释吗? 最佳答案 在test方法定义中无法访问ff的原因很简单,方法(使用def关键字创建)创建了一个新范围。与分别使用class和module关键字定义类和模块相同。在这种情况下,main(顶级对象)的作用几乎与作用域问题完全无关。请注意,如果您确实希望您的test方法能够访问在定义上下文中定义
例如,如果我有一个用户模型并且我只需要验证登录(这可能发生在通过ajax验证表单时),那么如果我使用用户模型中定义的相同模型验证而不实际实例化会很棒一个用户实例。所以在Controller中我可以编写如下代码User.valid_attribute?(:login,"loginvalue")无论如何我可以做到这一点吗? 最佳答案 由于验证是在实例上运行的(并且它们使用实例的错误属性作为错误消息的容器),所以您不能在没有实例化对象的情况下使用它们。话虽如此,您可以将此所需行为隐藏到类方法中:classUservalue)unlessm
所以,我很好奇Ruby为什么是一种完全面向对象的语言。我偶然发现了一个我不太清楚的问题。如果我定义一个函数如下deffoo(text)printtextend而且我在类之外定义函数,这个函数怎么是对象?我意识到我可以打电话foo.class然后我得到了NilClass。这是否意味着foo是NilClass的一个实例?如果是,当我打电话时它到底意味着什么foo"helloworld"如果foo是一个对象,那么当我进行上述语句时,我调用的是什么方法。另外,如果它是一个对象,是否意味着我可以修改它并向它添加另一个方法(比如bar),我可以在其中进行以下声明:foo.bar(somevaria
我有一堆函数接受对象数组,或设计为被视为包含一个对象的数组的单个对象,我正在寻找一种更简洁的方法来实现这一点。基本上,我想知道如何使以下函数中的unless部分更简洁:deffoo(bar_or_bars)unlessbar_or_bars.is_a?(Array)bar_or_bars=[bar_or_bars]endbar_or_bars.each{ |baz|...}end任何帮助将不胜感激!谢谢。 最佳答案 最简单的解决方案是使用内核方法Array:Array(5)#=>[5]Array([1,2,3])#=>[1,2,3]